## http://sparksandflames.com/files/x86InstructionChart.html

## **Addressing Method Codes**



- A ModR/M byte follows the opcode and specifies the operand. The operand is either an MMX<sup>™</sup> technology register or a memory address. If it is a memory address, the address is computed from a segment register and any of the following values: a base register, an index register, a scaling factor, and a displacement.
- R The mod field of the ModR/M byte may refer only to a general register (for example, MOV (0F20-0F24, 0F26)).
- S The reg field of the ModR/M byte selects a segment register (for example, MOV (8C,8E)).
- The reg field of the ModR/M byte selects a test register (for example, MOV (0F24,0F26)).
- V The reg field of the ModR/M byte selects a packed SIMD floating-point register.
- An ModR/M byte follows the opcode and specifies the operand. The operand is either a SIMD floating-point register or a memory address. If it is a memory address, the address is computed from a segment register and any of the following values: a base register, an index register, a scaling factor, and a displacement
- X Memory addressed by the DS:SI register pair (for example, MOVS, CMPS, OUTS, or LODS).
- Y Memory addressed by the ES:DI register pair (for example, MOVS, CMPS, INS, STOS, or SCAS).

## **Operand Type Codes**

- Two one-word operands in memory or two double-word operands in memory, depending on operand-size attribute (used only by the BOUND instruction).
- b Byte, regardless of operand-size attribute.
- **C** Byte or word, depending on operand-size attribute.

| d  | Doubleword, regardless of operand-size attribute               |
|----|----------------------------------------------------------------|
|    |                                                                |
| dq | Double-quadword, regardless of operand-size attribute.         |
|    |                                                                |
| p  | 32-bit or 48-bit pointer, depending on operand-size attribute. |
|    |                                                                |
| pi | Quadword MMX™ technology register (e.g. mm0)                   |
|    |                                                                |
| ps | 128-bit packed FP single-precision data.                       |
|    |                                                                |
| q  | Quadword, regardless of operand-size attribute.                |
|    |                                                                |
| S  | 6-byte pseudo-descriptor.                                      |
|    |                                                                |
| SS | Scalar element of a 128-bit packed FP single-precision data.   |
|    |                                                                |
| si | Doubleword integer register (e.g., eax)                        |
|    |                                                                |
| V  | Word or doubleword, depending on operand-size attribute.       |
|    |                                                                |
| W  | Word, regardless of operand-size attribute.                    |
|    |                                                                |